## 1. Aim of the Experiment/Simulation (Task details):

To:

- Design a Traffic Light Controller using FSM.
- Write the Verilog code and Verify with Test Bench

## 2. Name of the Simulation Platform/Tools: (If applicable)

Model-Sim

3. Theory:



## **Description of states**

| State | State<br>(Binary) | State Name   | East       | North      | West       | South      |
|-------|-------------------|--------------|------------|------------|------------|------------|
| 0     | 000               | East_green   | Green      | Red        | Red        | Red        |
| 1     | 001               | East_yellow  | Yellow     | Red-Yellow | Red        | Red        |
| 2     | 010               | North_green  | Red        | Green      | Red        | Red        |
| 3     | 011               | North_yellow | Red        | Yellow     | Red-Yellow | Red        |
| 4     | 100               | West_green   | Red        | Red        | Green      | Red        |
| 5     | 101               | West_yellow  | Red        | Red        | Yellow     | Red-Yellow |
| 6     | 110               | South_green  | Red        | Red        | Red        | Green      |
| 7     | 111               | South_yellow | Red-Yellow | Red        | Red        | Yellow     |

## **Emergency condition:**

|           | Emergency        |                  |                  |                  |              | State        |              |  |
|-----------|------------------|------------------|------------------|------------------|--------------|--------------|--------------|--|
| Direction | Emergency<br>[3] | Emergency<br>[2] | Emergency<br>[1] | Emergency<br>[0] | State<br>[2] | State<br>[1] | State<br>[0] |  |
| East      | 1                | 0                | 0                | 0                | 0            | 0            | 0            |  |
| North     | 0                | 1                | 0                | 0                | 0            | 1            | 0            |  |
| West      | 0                | 0                | 1                | 0                | 1            | 0            | 0            |  |
| South     | 0                | 0                | 0                | 1                | 1            | 1            | 0            |  |

# Jam Condition:

|           | Jam        |            |            |            | State        |              |              |
|-----------|------------|------------|------------|------------|--------------|--------------|--------------|
| Direction | Jam<br>[3] | Jam<br>[2] | Jam<br>[1] | Jam<br>[0] | State<br>[2] | State<br>[1] | State<br>[0] |
| East      | 1          | 0          | 0          | 0          | 0            | 0            | 0            |
| North     | 0          | 1          | 0          | 0          | 0            | 1            | 0            |
| West      | 0          | 0          | 1          | 0          | 1            | 0            | 0            |
| South     | 0          | 0          | 0          | 1          | 1            | 1            | 0            |

## 4. State diagram:



### 5. Verilog HDL Code and Outputs:

```
// Tarun Rithvik B (23BEC0014)
module
Traffic Light Controller(East road, North road, West road, South road, clk, rst, Emergency, Jam, E
mpty);
input clk,rst;
input [3:0]Emergency, Jam, Empty;//Emergency/Jam/Empty=0000, for east 1000, north 0100, west
0010, south 0001
output reg[2:0]
East road, North road, West road, South road; // Red=100, Yellow=010, Green=001, Red&Yellow=
110.none=000
reg[2:0] state;
parameter [2:0] east green=3'b000;
parameter [2:0] east yellow=3'b001;
parameter [2:0] north green=3'b010;
parameter [2:0] north yellow=3'b011;
parameter [2:0] west green=3'b100;
parameter [2:0] west yellow=3'b101;
parameter [2:0] south green=3'b110;
parameter [2:0] south yellow=3'b111;
reg[4:0] count;
always@(posedge clk, negedge rst)
 begin
 if(!rst)
  begin
  count=5'b00000;
  end
 else if(|Emergency)
  begin
  state={Emergency[1]|Emergency[0],Emergency[2]|Emergency[0],1'b0};
  count=5'b00000;
  end
 else if(|Jam)
  begin
  state = {Jam[1]|Jam[0],Jam[2]|Jam[0],1'b0};
  count=5'b00000:
  end
 else
  begin
   case(state)
   east green:
     begin
      if(count = 5'b10011 || Empty = 4'b1000)
```

```
begin
   count=5'b00000;
   state=east yellow;
   end
  else
   begin
   count=count+5'b00001;
   state=east green;
   end
  end
east yellow:
 begin
  if(count==5'b00011)
  begin
  count=5'b00000;
  state=north_green;
  end
  else
   begin
   count=count+5'b00001;
   state=east yellow;
   end
  end
north_green:
 begin
  if(count==5'b10011||Empty==4'b0100)
  begin
   count=5'b00000;
   state=north_yellow;
   end
  else
   begin
   count=count+5'b00001;
   state=north green;
   end
  end
north yellow:
 begin
  if(count==5'b00011)
  begin
  count=5'b00000;
  state=west green;
  end
  else
   begin
   count=count+5'b00001;
   state=north yellow;
   end
  end
```

```
west_green:
 begin
  if(count==5'b10011||Empty==4'b0010)
  begin
   count=5'b00000;
   state=west_yellow;
   end
  else
   begin
   count=count+5'b000001;
   state=west green;
   end
  end
west_yellow:
 begin
  if(count==5'b00011)
  begin
  count=5'b00000;
  state=south green;
  end
  else
   begin
   count=count+5'b00001;
   state=west_yellow;
   end
  end
south green:
 begin
  if(count==5'b10011||Empty==4'b0001)
  begin
   count=5'b00000;
   state=south yellow;
   end
  else
   begin
   count=count+5'b00001;
   state=south green;
   end
  end
south yellow:
 begin
  if(count==5'b00011)
   begin
   count=5'b00000;
   state=east green;
   end
  else
   begin
```

```
count=count+5'b00001;
     state=south yellow;
     end
    end
  default:
   begin
    count=5'b00000;
    state=east green;
   end
 endcase
 end
end
//Red=100,Yellow=010,Green=001,Red&Yellow=110,none=000
always@(state)
begin
 if(!rst)
  begin
  East road=3'b000;
  North road=3'b000;
  West road=3'b000;
  South road=3'b000;
  end
 else
 begin
 case(state)
  east_green:
  begin
  East road=3'b001;
  North road=3'b100;
  West road=3'b100;
  South road=3'b100;
  end
  east_yellow:
  begin
   East road=3'b010;
  North road=3'b110;//
  West road=3'b100;
  South road=3'b100;
  end
  north green:
  begin
   East road=3'b100;
   North road=3'b001;
   West road=3'b100;
   South road=3'b100;
```

```
end
   north yellow:
    begin
    East road=3'b100;
    North road=3'b010;
    West road=3'b110;//
    South road=3'b100;
    end
   west green:
    begin
    East road=3'b100;
    North_road=3'b100;
    West road=3'b001;
    South road=3'b100;
    end
   west_yellow:
    begin
    East road=3'b100;
    North road=3'b100;
    West road=3'b010;
    South road=3'b110; //
    end
   south_green:
    begin
    East_road=3'b100;
    North road=3'b100;
    West road=3'b100;
    South road=3'b001;
    end
   south yellow:
    begin
    East road=3'b110;//
    North_road=3'b100;
    West road=3'b100;
    South road=3'b010;
    end
   endcase
  end
 end
endmodule
module tb_Traffic_Light_Controller;
 reg clk;
 reg rst;
 reg [3:0] Emergency;
```

```
reg [3:0] Jam;
reg [3:0] Empty;
wire [2:0] East road;
wire [2:0] North road;
wire [2:0] West road;
wire [2:0] South road;
Traffic Light Controller uut (
 .clk(clk),
 .rst(rst),
 .Emergency(Emergency),
 .Jam(Jam),
 .Empty(Empty),
 .East road(East road),
 .North road(North road),
 .West_road(West_road),
 .South road(South road)
);
always #5 clk = \sim clk;
initial begin
 clk = 0;
 rst = 1;
 Emergency = 4'b0000;
 Jam = 4'b0000;
 Empty = 4'b0000;
 #10;
 rst = 0;
 #10;
 rst = 1;
 #20;
 Empty = 4'b0000;
 #200;
 Emergency = 4'b1000;
 #20;
 Emergency = 4'b0000;
 #20;
 Jam = 4'b0100;
 #20;
 Jam = 4'b0000;
 #20;
 Empty = 4'b1000;
 #40;
 Empty = 4'b0100;
 #40;
 Empty = 4'b0010;
 #40;
 Empty = 4'b0001;
 #40;
```

```
Empty = 4'\overline{b0000};
   #200;
   $stop;
 end
 initial begin
   $monitor("Time=%0t | East=%b | North=%b | West=%b | South=%b | Emergency=%b |
Jam=%b | Empty=%b",
           $time, East road, North road, West road, South road, Emergency, Jam, Empty);
 end
endmodule
        // Tarun Rithvik B (23BEC0014)
       Findule Traffic_Light_Controller(East_road,North_road,West_road,South_road,clk,rst,Emergency,Jam,Empty);
          input [3:0]Emergency, Jam, Empty;//Emergency/Jam/Empty=0000, for east 1000, north 0100, west 0010, south 0001 output reg[2:0] East_road, North_road, West_road, South_road;//Red=100, Yellow=010, Green=001, Red&Yellow=110, none=000
          reg[2:0] state;
         parameter [2:0] east_green=3'b000;
parameter [2:0] east_yellow=3'b001;
parameter [2:0] north_green=3'b010;
   11
12
         parameter [2:0] north_green=3'b010;
parameter [2:0] west_green=3'b100;
parameter [2:0] west_yellow=3'b101;
parameter [2:0] south_green=3'b110;
parameter [2:0] south_yellow=3'b111;
   13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
          reg[4:0] count;
          always@(posedge clk, negedge rst)
           begin
            if (!rst)
             begin
             count=5'b00000;
             end
            else if (|Emergency)
   30
             state={Emergency[1] | Emergency[0], Emergency[2] | Emergency[0],1'b0};
   31
              count=5'b00000;
                  else if(|Jam)
    34
    35
                    state={Jam[1]|Jam[0],Jam[2]|Jam[0],1'b0};
    37
                   count=5'b00000;
    38
                   end
    39
    40
                  else
           中中
    41
                   begin
    42
                     case (state)
    43
    44
                       east green:
    45
                           begin
                             if (count==5'b10011||Empty==4'b1000)
    46
    47
                                begin
                                  count=5'b000000;
    48
    49
                                  state=east_yellow;
                                 end
                             else
    52
                                begin
    53
                                count=count+5'b00001;
    54
                                state=east_green;
    55
                                end
    56
                             end
                        east yellow:
    59
                           begin
                             if (count==5'b00011)
    60
    61
                                begin
                                 count=5'b000000;
    63
                                state=north green;
                                 end
    65
                              else
    66
                                begin
```

```
count=count+5'b00001;
  67
  68
                       state=east yellow;
  69
                       end
  70
                     end
  71
                north_green:
  72
  73
                   begin
  74
                     if (count==5'b10011||Empty==4'b0100)
  75
                      begin
                       count=5'b00000;
  76
                       state=north yellow;
  78
                       end
  79
                     else
  80
       白
                       begin
  81
                       count=count+5'b00001;
  82
                       state=north green;
  83
                       end
  84
                     end
  85
  86
               north yellow:
  87
                   begin
  88
                     if (count==5'b00011)
  89
                       begin
  90
                       count=5'b00000;
  91
                       state=west green;
  92
                       end
  93
                     else
  94
                       begin
  95
                       count=count+5'b00001;
  96
                       state=north_yellow;
  97
                       end
  98
                     end
  99
100
            west_green:
      中
101
              begin
102
                if (count==5'b10011||Empty==4'b0010)
     中
103
                  begin
104
                  count=5'b000000;
105
                  state=west_yellow;
106
                  end
107
                else
     中
108
                  begin
109
                  count=count+5'b0000001;
110
                  state=west_green;
111
                  end
               end
112
113
            west_yellow:
114
     白
115
               begin
                if (count==5'b00011)
116
117
     中
                  begin
                  count=5'b000000;
118
119
                  state=south_green;
120
                  end
121
               else
122
                  begin
123
                  count=count+5'b000001;
124
                  state=west_yellow;
125
                  end
126
                end
127
128
             south_green:
129
     中
               begin
                if (count==5'b10011||Empty==4'b0001)
130
131
     ¢
                  begin
                  count=5'b000000;
132
133
                  state=south yellow;
134
                  end
135
               else
136
                  begin
137
                  count=count+5'b000001;
```

```
138
                     state=south green;
 139
                     end
 140
                  end
 141
 142
              south_yellow:
 143
       白
                 begin
                  if (count==5'b00011)
 144
       4
 145
                    begin
 146
                    count=5'b000000;
 147
                     state=east_green;
 148
                     end
 149
                 else
       中
 150
                    begin
 151
                    count=count+5'b00001;
                    state=south_yellow;
 152
 153
                    end
 154
                 end
 155
 156
              default:
       中
 157
                 begin
                   count=5'b000000;
 158
 159
                   state=east_green;
 160
 161
 162
 163
             endcase
 164
             end
 165
            end
 166
           //Red=100, Yellow=010, Green=001, Red&Yellow=110, none=000
 167
 168
          always@(state)
 169
      -
            begin
 170
             if (!rst)
       白
 171
               begin
                 East road=3'b000;
 172
 173
                North_road=3'b000;
                 West_road=3'b000;
 174
175
                 South road=3'b000;
176
                end
 177
             else
       自
 178
              begin
 179
              case (state)
 180
 181
               east_green:
 182
       中
                begin
 183
                 East_road=3'b001;
 184
                 North_road=3'b100;
 185
                 West_road=3'b100;
 186
                 South_road=3'bl00;
 187
                end
 188
 189
               east_yellow:
 190
       白
                begin
 191
                 East road=3'b010;
 192
                 North_road=3'b110;//
                 West_road=3'b100;
 193
 194
                 South_road=3'b100;
 195
                end
 196
 197
               north_green:
 198
       中
                begin
 199
                 East_road=3'b100;
 200
                 North road=3'b001;
 201
                 West_road=3'b100;
                 South_road=3'b100;
 202
 203
                end
 204
 205
               north_yellow:
 206
       白
                begin
                 East_road=3'b100;
 207
 208
                 North_road=3'b010;
 209
                 West_road=3'b110;//
                 South_road=3'b100;
 210
 211
                end
 212
213
               west green:
```

```
214
                begin
 215
                 East_road=3'b100;
 216
                 North road=3'b100;
                 West_road=3'b001;
 217
 218
                 South road=3'b100;
 219
 220
 221
               west_yellow:
 222
                begin
 223
                 East_road=3'b100;
 224
                 North road=3'bl00;
                 West_road=3'b010;
 225
                 South road=3'b110; //
 226
 227
                end
 228
 229
              south_green:
 230
                begin
 231
                 East road=3'b100;
 232
                 North road=3'b100;
                 West_road=3'b100;
 233
 234
                 South_road=3'b001;
 235
               end
 236
              south_yellow:
 237
 238
               begin
 239
                 East road=3'bl10;//
                 North road=3'b100;
 240
                 West_road=3'bl00;
 241
 242
                 South road=3'b010;
 243
                end
 244
 245
             endcase
 246
             end
      endmodule
 247
 248
 249
 250
      module tb_Traffic_Light_Controller;
251
 252
           reg clk;
 253
            reg rst;
 254
            reg [3:0] Emergency;
 255
           reg [3:0] Jam;
 256
            reg [3:0] Empty;
 257
           wire [2:0] East_road;
wire [2:0] North_road;
 258
 259
 260
            wire [2:0] West road;
 261
           wire [2:0] South road;
 262
       Traffic_Light_Controller uut (
 263
 264
             .clk(clk),
 265
              .rst(rst),
 266
              . Emergency (Emergency) ,
 267
              .Jam (Jam),
 268
             . Empty (Empty),
 269
              .East_road(East_road),
 270
             .North road (North road) ,
 271
              .West_road(West_road),
 272
              . South_road (South_road)
 273
 274
 275
           always #5 clk = ~clk;
initial begin
 276
  277
 278
 279
              clk = 0;
              rst = 1;
 280
 281
             Emergency = 4'b0000;
 282
              Jam = 4'b00000;
 283
              Empty = 4'b00000;
 284
              #10;
 285
              rst = 0;
 286
              #10;
 287
              rst = 1;
 288
              #20:
289
              Empty = 4'b0000;
```

```
Emergency = 4'b1000;
 291
 292
             #20:
 293
             Emergency = 4'b0000;
294
             #20;
 295
             Jam = 4'b0100;
 296
            #20;
 297
             Jam = 4 b00000;
 298
             #20;
            Empty = 4'b1000;
 299
 300
             #40;
 301
             Empty = 4'b0100;
 302
 303
            Empty = 4'b0010;
 304
             #40:
             Empty = 4'b0001;
 305
306
             #40;
             Empty = 4'b0000;
 307
 308
            #200;
 309
             Sstop;
 310
          end
 311
312 p initial begin
313 p smonitor("Ti
           $monitor("Time=%0t | East=%b | North=%b | West=%b | South=%b | Emergency=%b | Jam=%b | Empty=%b",
 314
                      $\time, East_road, North_road, West_road, South_road, Emergency, Jam, Empty);
315
      endmodule
 316
317
```

### **Output:**



#### 6. **Conclusions:**

Thus using the above logic we have designed a 4 way traffic control system.